给你一个序列 a,求出这个序列中互质数的有多少对。
其中所有的整数的都小于等于 222222 。
题解
- 设$f(d)$为$\gcd$恰好为$d$的对数
- 设$F(d)$为$\gcd$为$d$的倍数的对数
- 所以$F(d)=\sum _{d|n}f(n)$
- 莫比乌斯反演可得,$f(d)=\sum_{d|n} \mu(\frac{n}{a})·F(n)$
- 问题求的为$f(1)$,即$\sum \mu(n)·F(n)$
- $F(n)$ 可以用 $cnt[i]$: 这个序列中 $i$ 的个数,$num[i]$: 表示这个序列中为 $i$ 的倍数的数字的个数,$O(nlogn)$ 既可以处理出所有的 $F(n)$
代码
1 | // 没测过不一定对 |